Skip to content

Conversation

@jeffabailey
Copy link
Contributor

@jeffabailey jeffabailey commented Feb 28, 2025

This pattern has been around in a draft/initial stage for a long time (almost 8 hears)!

As we believe that it does add some interest points, we want to try to improve it so that we feel comfortable publishing it in our pattern book.

Checklist

from the Contributor Handbook:

Extras

  • TBD

History

Copy link
Member

@spier spier left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I pushed some changes to align the pattern with our pattern template.

Overall I think this is an interesting pattern, that has some way to go before being ready to be published to our book though.

My main concerns right now are:

  • The Solution section contains multiple different things. What are the core aspects of the solution? Maybe we could try to group the bullets into categories, and give each category a distinct name to find out what the overarching themes of the solution are.
  • How is this pattern related to other patterns like InnerSource Portal and Gig Marketplace?
  • Not sure what to do with the "Discussion on" section. this seems more like meeting notes from a discussion that must have happened a long time ago. Maybe we can ask people that are still around if they remember anything about this pattern, like @gruetter and @NewMexicoKid

Besides that, we would have to check the requirements here before publishing to the book: Contributor Handbook - Requirements for maturity 'Structured'

If the ambition here is to have a better version of this pattern merged into our repo, I would recommend to leave this in the Initial state (and folder) for a bit longer. This would allow us to make some fixes and merge these PRs faster.

If the ambition is to get this pattern live in our book, then we will have to invest quite some work here and keep the PR open for a while.

Either way is fine with me, I just want to prevent frustrations as I don't know what your expectations are here.

@spier
Copy link
Member

spier commented Mar 4, 2025

Btw @jeffabailey if you want to use this pattern as a way to learn what it takes to get a pattern ready for publication in the book, by all means, keep pushing :) Just it might not be the easiest path on this particular pattern, as the current content of the pattern leaves a lot of room for improvement.

@spier spier added the 📖 Type - Content Work Working on contents is the main focus of this issue / PR label Mar 4, 2025
@jeffabailey
Copy link
Contributor Author

I pushed some changes to align the pattern with our pattern template.

Awesome, thank you!

If the ambition is to get this pattern live in our book, then we will have to invest quite some work here and keep the PR open for a while.

This, TBH! :)

Just it might not be the easiest path on this particular pattern, as the current content of the pattern leaves a lot of room for improvement.

Sounds like a great challenge and learning opportunity.

I'll read through more of the published patterns to align this one closer to the others.

I was having a conversation with @rrrutledge about what constitutes an approachable and useful pattern.

The patterns listed on the fearless change website are an interesting overlay to the patterns.

https://fearlessjourney.info/fearless-change-patterns/

I really like "Discover Your InnerSource" name for the pattern.

What do you think about the name?

How is this pattern related to other patterns like InnerSource Portal and Gig Marketplace?

Another great question to answer after defining the appropriate name and scope for this pattern.

@jeffabailey jeffabailey requested a review from spier April 2, 2025 00:56
@spier
Copy link
Member

spier commented Apr 2, 2025

@jeffabailey I took some liberties and added the checklist for maturity Structured to the initial message of this PR. That gives us some guidelines for the various things that we want to check before promoting this pattern to our book.

Copy link
Member

@spier spier left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The biggest challenge I see in this pattern at the moment is the Solution section.

  • Some of the bullets in the Solution section propose things that already exist as dedicated patterns. We could link to them.
    • Aside: this is not surprizing as some of those other patterns might have not existed 8 years ago when this pattern was drafted
  • Through that we might also figure what is the "net new" content in this pattern.
  • How is this pattern related to these patterns

I suspect my comments may seem overly critical of this pattern.

However my goal is to only publish useful patterns to the book. And given that this pattern has not been touched in so long, it will need a bit of love/work to be ready for prime time :)

@spier
Copy link
Member

spier commented Apr 13, 2025

Sorry about the mess that I made with my last 3 commits. I was on the wrong branch. I cleaned it all up again (I hope), and committed those changes to #779 instead.

@jeffabailey
Copy link
Contributor Author

jeffabailey commented Apr 17, 2025

  1. InnerSource Portal - highlight key InnerSource projects, with a focus on highlighting projects that are actively promoting themselves as InnerSource

  2. Unified Source Code Inventory - aggregate projects from various version control systems in a single place, no matter if they are closed source, InnerSource or open source

  3. Discover your InnerSource - the behavioral changes required by developers to "look for InnerSource first" (described so well by Cursor!). maybe combined with the concierge service idea.

Here's a comparison of concepts introduced in the three patterns using a custom GPT I created that sources our InnerSource Patterns and Managing InnerSource Projects book.

🧭 InnerSource Pattern Comparison Table

Concept InnerSource Portal Unified Source Code Inventory Discover Your InnerSource Best-Fit Pattern for Practitioner
Highlighting InnerSource projects ✅ Central function: promoting InnerSource visibility ❌ Not focused on promotion 🔸 Indirectly, via encouragement to explore InnerSource Portal
Aggregating all source code (IS, closed, open) 🔸 May include some InnerSource projects ✅ Core purpose: unify all codebases ❌ Not applicable Unified Source Code Inventory
Making InnerSource discoverable ✅ Projects curated for discoverability ✅ Through aggregation of all sources ✅ Cultural push to explore and adopt InnerSource All (tech: Inventory & Portal; behavior: Discover)
Encouraging "InnerSource first" mindset 🔸 Reinforces via visibility ❌ Not focused on mindset ✅ Primary goal — shift developer behavior Discover Your InnerSource
Concierge service / guided onboarding ❌ Not included ❌ Not included ✅ Often part of behavioral support (e.g., internal advocates) Discover Your InnerSource
Cross-system code search 🔸 Might link out ✅ Key feature — aggregates across systems ❌ Not part of scope Unified Source Code Inventory
Rewarding teams for InnerSource openness ✅ Visibility acts as incentive ❌ Does not emphasize recognition 🔸 Could be part of cultural change strategy InnerSource Portal
Single entry point for exploring InnerSource ✅ Designed for this 🔸 Possible via UI aggregation 🔸 Encouraged behavior InnerSource Portal
Supports culture change / developer behavior shift 🔸 Visibility aids change ❌ Purely technical ✅ Central goal — behavior and mindset change Discover Your InnerSource

💡 Summary

  • InnerSource Portal: Best for visibility, promotion, and incentivizing InnerSource openness.

  • Unified Source Code Inventory: Best for technical aggregation and removing silos across repositories.

  • Discover Your InnerSource: Best for cultural transformation, onboarding support, and developer behavior change.

Here's the prompt I used to produce this table.


Compare these InnerSource Patterns and describe overlapping concepts while suggesting which pattern is most suited to contain individual concepts for an InnerSource practitioner.

Create a table.


 InnerSource Portal - highlight key InnerSource projects, with a focus on highlighting projects that are actively promoting themselves as InnerSource
   
 Unified Source Code Inventory - aggregate projects from various version control systems in a single place, no matter if they are closed source, InnerSource or open source
   
Discover your InnerSource - the behavioral changes required by developers to "look for InnerSource first" (described so well by Cursor!). maybe combined with the concierge service idea.

So maybe one could stay 1 and 2 are about tooling, while 3 is not?

That sounds reasonable. The table suggests that 3. is about culture and behavioral, and mindset changes. It seems the name of this pattern is moving toward "Promote Project Discovery" rather than "Discover Internal Code" or "Discover Internal Projects".

The idea of providing actual search functionality would fit equally well in 1 and 2, wouldn't it? Neither of these patterns has been very explicit about how to set up a good search engine with a focus on InnerSource though. My suspicion is that most orgs re-use the search functionality of their VCS (github, gitlab, ...) to accomplish this. Some might use Backstage.

It depends on if we want to make this pattern about behavior, tooling, or both.

@spier
Copy link
Member

spier commented Apr 18, 2025

This is really cool @jeffabailey . The comparison table with concepts, the 3 patterns, and the best-fit pattern is super helpful!

I have various thoughts about different aspects of this. I will reply in separate comments, so that it becomes easier to separate the conversations.

@spier
Copy link
Member

spier commented Apr 18, 2025

The way that you used AI support here is interesting. I have used ChatGPT for creating pattern drafts, but not for comparing patterns so yet.

Here's a comparison of concepts introduced in the three patterns using a custom GPT I created that sources our InnerSource Patterns and Managing InnerSource Projects book.

I looked at your ChatGPT prompt. How did you add InnerSource Patterns and Managing InnerSource Projects book as sources thought? I cannot see how that works in the prompt.

@spier
Copy link
Member

spier commented Apr 18, 2025

The comparison table is helpful for figuring out what the core focus of each of the existing patterns is, and how new patterns can add new insights to "fill the gaps" between the existing patterns.

I wonder if such overviews/comparisons could be published as a new content type in our InnerSource patterns book (or elsewhere). If I had to give such write-ups a name I might call it "scenario", "use case", or even just "article".

e.g. we could publish a scenario called "Enable project reuse". In that scenario we would incorporate the comparison table above, and point to patterns immediately related to the scenario (e.g. the 3 patterns that we are discussing here, and potentially others).

I will post that idea as a new issue, so that it can be discussed separate from this PR here.

@jeffabailey
Copy link
Contributor Author

I looked at your ChatGPT prompt. How did you add InnerSource Patterns and Managing InnerSource Projects book as sources thought? I cannot see how that works in the prompt.

I used using my ChatGPT account to create a custom GPT.

image

Clicking on the innersourcecommons.org config at the bottom of this image, I added this schema.

openapi: 3.1.0
info:
  title: InnerSource Commons Website API
  version: 1.0.0
  description: >
    Access content from the InnerSource Commons public website.
    This API allows retrieving pages and resources from the live website.
servers:
  - url: https://innersourcecommons.org
paths:
  /{path}:
    get:
      operationId: getWebsiteContent
      summary: Get content from the InnerSource Commons website
      parameters:
        - name: path
          in: path
          required: true
          description: >
            Path to a page or resource on the website
            (e.g. `about/privacy`, `learning/patterns`)
          schema:
            type: string
      responses:
        '200':
          description: Page content returned successfully
          content:
            text/html:
              schema:
                type: string
                description: HTML content of the page
        '404':
          description: Page not found
  /:
    get:
      operationId: getHomepage
      summary: Get the website homepage
      responses:
        '200':
          description: Homepage content returned successfully
          content:
            text/html:
              schema:
                type: string
                description: HTML content of the homepage

This uses https://innersourcecommons.org as a source.

The other config is for api.github.com, which navigates the GitHub API to pull information.

openapi: 3.1.0
info:
  title: InnerSource Commons GitHub API
  version: 1.1.1
  description: >
    Access structured content from InnerSource Commons repositories. Lists all content
    from both the Managing InnerSource Projects book and InnerSource Patterns repositories.
servers:
  - url: https://api.github.com/repos/InnerSourceCommons
    description: GitHub API endpoint for InnerSource Commons repositories
security:
  - github_auth: []
paths:
  /{repository}/contents:
    get:
      operationId: listRepositoryContents
      summary: List all repository content
      description: >
        Lists all content from the specified repository. Supports both the Managing InnerSource Projects
        book and InnerSource Patterns repositories. Returns metadata about each file including its path
        and download URL.
      parameters:
        - name: repository
          in: path
          required: true
          schema:
            type: string
            enum: [managing-innersource-projects, InnerSourcePatterns]
          description: The repository to list contents from
        - name: path
          in: query
          required: false
          schema:
            type: string
          description: The path to list contents from
        - name: ref
          in: query
          required: false
          schema:
            type: string
          description: The name of the commit/branch/tag
      responses:
        "200":
          description: A list of all repository content files
          content:
            application/json:
              schema:
                type: array
                items:
                  $ref: "#/components/schemas/GitHubContent"
        "404":
          description: Repository or content not found

components:
  schemas:
    GitHubContent:
      type: object
      properties:
        name:
          type: string
          description: The filename of the content
        path:
          type: string
          description: Full path to the content file
        sha:
          type: string
          description: The SHA of the content
        size:
          type: integer
          description: The size of the content
        url:
          type: string
          description: The API URL to fetch the content
        html_url:
          type: string
          description: GitHub web URL to view the content
        git_url:
          type: string
          description: The Git URL to fetch the content
        download_url:
          type: string
          description: Direct URL to download the raw content
          nullable: true
        type:
          type: string
          enum: [file, dir]
        _links:
          type: object
          properties:
            self:
              type: string
            git:
              type: string
            html:
              type: string

  securitySchemes:
    github_auth:
      type: http
      scheme: bearer
      description: GitHub API token for authentication

@rrrutledge
Copy link
Contributor

How to share and promote this in the community in general? Website/slack/etc?
I wrote document with some background about scenarios that might be useful to fil with such a bot. Check it out in case it's useful: https://docs.google.com/document/d/1L08FcP6GLtyZxKkOc1QzHothR9kvBnqgG80YYkKBtgc/edit?tab=t.0#heading=h.12qwh2uatj32

* Pull in Repo names, descriptions and README.md files into the search engine assuming that a search engine exists. Note: a one-stop-shop kind of search engine for all relevant communication and documentation is difficult to attain. Even when using Github's enterprise offering, people often deploy additional systems like wikis to host content orthogonal to what is in the code repositories, slack channels (or IRC), mailing lists (or even nntp servers), some place to store stuff written down in office formats, search over personal e-mail etc. Several of these systems come with search built-in, but integrating this content in one search box or even just deploying a federated search engine across all sources often doesn't come off-the-shelf.
* Consider using existing tools:
* GitHub Enterprise and npmjs have built-in searches on meta-data
* PayPal's Agora project (planned to be open sourced) addresses similar challenges with data source integration
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I could not find a mention of the PayPal Agora project anywhere.
So either they renamed it, or they never open sourced it.

We could potentially ask the ex-PayPal people for help here.

Or we remove this entire sentence, if it is not adding helpful info to this pattern.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Sounds good to me!

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

It was open sourced as SeazMe, but no activity around it for a long time.

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Thanks for the link Russ.

They even mention the ISC in the Readme. But yeah, archived in 2020.

This could be one of those software assets that we port to our GitHub org. However probably not worthwhile if there are no users of the software.

Aside: maybe I should search GitHub for so mentioned of the InnerSource Commons.

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@rrrutledge I added the SeazMe link to this pattern itself, as a replacement for Agora.

I read parts of the documentation, but am still somewhat unsure as to what SeazMe actually is (or rather was).

It looks like a federated search engine across multiple data sources.

So it is not an implementation of an InnerSource Portal, or is it?

Any idea why PayPal discontinued the development?
i.e. are they using something else now instead of SeazMe, or do they use nothing at all?

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

It is mostly the search engine.

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Silona left, who was championing the effort.

@spier
Copy link
Member

spier commented May 23, 2025

@jeffabailey it has been some time since I looked at this PR, so I have forgotten a bit what we talked about before.

To confirm: You are pushing to get this pattern published in the book, right? i.e. get it to maturity structured?

I read the pattern again. My sense is that if we would focus this pattern on the behavior change only, then this might make things easier for us. If necessary, we can move elements from this pattern that relate to tooling into the InnerSource Portal pattern instead.

What do you think about that approach?

@jeffabailey
Copy link
Contributor Author

I read the pattern again. My sense is that if we would focus this pattern on the behavior change only, then this might make things easier for us. If necessary, we can move elements from this pattern that relate to tooling into the InnerSource Portal pattern instead.

What do you think about that approach?

Sounds like a good approach to me.

* Pull in repo names, descriptions and `README.md` files into the search engine assuming that a search engine exists. Note: a one-stop-shop kind of search engine for all relevant communication and documentation is difficult to attain. Even when using GitHub's enterprise offering, people often deploy additional systems like wikis to host content orthogonal to what is in the code repositories, slack channels (or IRC), mailing lists (or even nntp servers), some place to store stuff written down in office formats, search over personal e-mail etc. Several of these systems come with search built-in, but integrating this content in one search box or even just deploying a federated search engine across all sources often doesn't come off-the-shelf.
* Consider using existing tools:
* GitHub Enterprise and npmjs have built-in searches on meta-data
* PayPal's [SeazMe](https://github.com/paypal/seazme) project (previously called Agora) addresses similar challenges with data source integration
Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Do we want to remove this since the project is archived?

If we don't, does it make sense to add Agora to Vale per the check failure?

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

📖 Type - Content Work Working on contents is the main focus of this issue / PR

Projects

Status: In Progress

Development

Successfully merging this pull request may close these issues.

4 participants